

Computer Engineering Dept. Faculty of Engineering Cairo University

Computer Architecture Lab #1

## **Computer Architecture Lab #1**

You will design a part of <u>16-bit</u> ALU that accepts 2 16-bit input values "A" and "B" and provides 16-bit output "F". The ALU has 4-bit selection inputs "S" (S0->3) and "Cin" input. The required part of the ALU provides a total of 12 operations specified in the following table

|        | S <sub>3</sub> | S <sub>2</sub> | S <sub>1</sub> | So |                             |  |
|--------|----------------|----------------|----------------|----|-----------------------------|--|
| Part A | 0              | 0              | 0              | 0  | Next Time                   |  |
|        | 0              | 0              | 0              | 1  |                             |  |
|        | 0              | 0              | 1              | 0  |                             |  |
|        | 0              | 0              | 1              | 1  |                             |  |
| Part B | 0              | 1              | 0              | 0  | F = A and B                 |  |
|        | 0              | 1              | 0              | 1  | F = A or B                  |  |
|        | 0              | 1              | 1              | 0  | F = A xor B                 |  |
|        | 0              | 1              | 1              | 1  | F = Not A                   |  |
| Part C | 1              | 0              | 0              | 0  | F=Logic shift right A       |  |
|        | 1              | 0              | 0              | 1  | F=Rotate right A            |  |
|        | 1              | 0              | 1              | 0  | F=Rotate right A with Carry |  |
|        | 1              | 0              | 1              | 1  | F=Arithmetic shift right A  |  |
| Part D | 1              | 1              | 0              | 0  | F=Logic shift left A        |  |
|        | 1              | 1              | 0              | 1  | F=Rotate left A             |  |
|        | 1              | 1              | 1              | 0  | F=Rotate left A with Carry  |  |
|        | 1              | 1              | 1              | 1  | F = 0000                    |  |

### **Requirement:**

You will design a part of **16-bit** ALU as follows:

Write VHDL code for parts B, C and D in 3 separate VHDL files **Each file is** .1 **named** as "partB", "partC", "partD" respectively.

- a. Part B ports
  - i. Input => A, B, S0, S1
  - ii. Output  $\Rightarrow$  F
- b. Part C ports
  - i. Inputs  $\Rightarrow$  A, Cin, S0, S1
  - ii. Output => F, Cout (the shifted/rotated bit)
- c. Part D ports
  - i. Inputs  $\Rightarrow$  A, Cin, S0, S1
  - ii. Output => F, Cout (the shifted/rotated bit)
- 2. Compile your Code, the code should be free of errors and warnings
- 3. Simulate each file using the inputs stated below.
- 4. **Assignment:** Integrate all 3 files in a bigger file, named "ALU", in structural way and use 4-bit "S" selection input to choose between components.
- 5. Your simulation will be delivered using **DO files** only.



Computer Engineering Dept. Faculty of Engineering Cairo University

# Computer Architecture Lab #1

| Operation                   | A    | В    | Cin | F    | Cout |
|-----------------------------|------|------|-----|------|------|
| AND                         | F00F | 000A |     | 000A |      |
| OR                          | F00F | 000A |     | F00F |      |
| XOR                         | F00F | 000A |     | F005 |      |
| NOT                         | F00F |      |     | 0FF0 |      |
| F=Logic shift right A       | F00F |      | -   | 7807 | 1    |
| F=Rotate right A            | F00F |      | _   | F807 | 1    |
| F=Rotate right A with Carry | F00F |      | 0   | 7807 | 1    |
| F=Rotate right A with Carry | F00F |      | 1   | F807 | 1    |
| F=Arithmetic shift right A  | F00F |      | _   | F807 | 1    |
| F=Logic shift left A        | F00F |      | _   | E01E | 1    |
| F=Rotate left A             | F00F |      | _   | E01F | 1    |
| F=Rotate left A with Carry  | F00F |      | 0   | E01E | 1    |
| F=Rotate left A with Carry  | F00F |      | 1   | E01F | 1    |
| F=0000                      | F00F |      | _   | 0000 | 0    |
| F=Rotate right A            | F00A |      | _   | 7805 | 0    |

# N.B. you will be graded for code neatness and understanding, Good luck

#### Self-assessment



- **1.** How to describe wires in VHDL?
- 2. What hardware does the when else statement maps to?
  - **3.** Is VHDL case sensitive?

### **Questions for Next Lab:**



- 1. If you need to use several sizes of the same component (i.e. 2-bit adder, 4-adder), is there a way to use the same entity definition for all sizes without creating single entity for each size?
- 2. What is a process?
- **3.** Draw a schematic for full adder.